草庐IT

sql - 表的时间分布

全部标签

ruby-on-rails - 如何将 Rails session cookie 过期时间设置为 "session"

我对Rails中不在表面上的部分不是很有经验。我想要的只是有一个sessioncookie,其过期时间设置为session,这样当用户离开浏览器或其他任何东西时它就会过期。作为安全措施。 最佳答案 默认情况下,cookie是sessioncookie。通过在config/initializers/session_store.rb中提供选项散列,您可以完全控制cookie。选项与Rack::Session::Cookie(seedocs)相同。因此,例如,对于特定的到期日期,您可以提供:expire_after。如果您使用Devise

sql - PostgreSQL 条件 where 子句

在我的RubyonRails应用程序中,我使用的是blazer(https://github.com/ankane/blazer)并且我有以下sql查询:SELECT*FROMsurvey_resultssrLEFTJOINclientscONc.id=sr.client_idWHEREsr.client_id={client_id}这个查询非常有效。但是我需要添加条件逻辑来检查client_id变量是否存在。如果是,那么我将按此变量进行过滤,如果不是,则我不会启动此where子句。我如何在PostgreSQL中执行此操作? 最佳答案

ruby-on-rails - 人性化时间

我有一些易腐烂的产品。因此,每个产品都有一个名为hours_expiration的属性,用于指示产品在变质之前可以使用多少小时。例如,苹果将在168小时后过期;坚果将在4320小时后过期。鉴于产品的到期时间和当前时间(Time.now或Date.now),我如何通过以下一些示例方式将到期时间人性化?您的商品设置为大约在以下时间过期:6个月零14天1个月零13天1个月零1天27天1天23小时1小时50分钟1分钟寻找强大而简单的东西! 最佳答案 Thedistance_of_time_in_wordshelper似乎是你要求的。

sql - 将所有 Controller 操作包装在 Rails 中的事务中

是否可以设置一个Rails应用程序,以便所有Controller操作都自动包装在一个事务中,并在出现未挽救的异常时自动回滚?我正在开发一个Rails3应用程序,目前正在执行一项相当棘手的操作,该操作会进行大量数据库更改。而且我一直弄错了很多次!一段时间后,我意识到我的代码无法正常工作,因为我最终在数据库中得到了不一致的数据。我可以很容易地用一个事务来包装它(这是一个明显需要的实例!)。然而,这让我想到,至少在开发过程中,将这个想法应用于每个Controller操作会很有用。假设这是可能的,这有什么缺点吗? 最佳答案 有关信息,我在我

ruby-on-rails - Rails ActiveRecord::StatementInvalid: PG::Error: ERROR: 缺少表的 FROM 子句条目

我有一个复杂的ActiveRecord查询,我正在根据用户的选择构建具有不同范围的查询。我正在使用2个gem,这似乎是有问题的,但我找不到谁是两者之间的罪魁祸首:Texticle(用于Postgresql完整搜索)(2.0.3)Squeel(用于ActiveRecord查询中的ruby​​语法)squeel(0.9.5)Arel或ActiveRecord本身这是我的类定义:classEvent"Entity",:foreign_key=>:entity_idbelongs_to:place,:class_name=>"Entity",:foreign_key=>:place_idcla

ruby - 在 Ruby 中将时间类对象转换为 RFC3339

GoogleCalendarAPI(v2)与时间相关的查询需要采用RFC3339格式。当我在“需要“时间””之后查找时间类时,我看不到rfc3339方法。 最佳答案 如果您使用的是ActiveRecord,则可以使用to_datetime方法将时间转换为DateTime对象。Time.now.to_datetime.rfc3339#=>"2014-11-06T10:40:54+11:00"参见:http://www.ruby-doc.org/stdlib-2.4.1/libdoc/date/rdoc/Time.html.

ruby-on-rails - SQL 注入(inject)和 ActiveRecord

这对SQL注入(inject)安全吗:Guest.where(:event_id=>params[:id])我在发送params[:id]时没有进行任何类型的清理。一般来说,所有这些activerecord方法都安全吗?(如where、joins等。)如果不是,安全的最佳做法是什么?另外,是否有任何我应该注意的警告/边缘情况?谢谢 最佳答案 ActiveRecord的所有查询构建方法,如where、group、order等等,都可以安全地防止SQL注入(inject)ASLONGAS您不向它们传递原始SQL字符串。这容易受到SQL注

ruby-on-rails - 如何检查 Ruby 中的变量是日期还是时间还是日期时间?

检查变量/对象是否属于Date/Time/DateTime类型的简单方法?没有命名所有类型 最佳答案 另一种选择:defis_datetime(d)d.methods.include?:strftimeend或者:ifd.respond_to?(:strftime)#disaDateorDateTimeobjectend 关于ruby-on-rails-如何检查Ruby中的变量是日期还是时间还是日期时间?,我们在StackOverflow上找到一个类似的问题:

sql - 在 AREL 中分组 ands 和 ors

我正在尝试使用arel查询此sql片段的等效项:WHERE(("participants"."accepted"='f'AND"participants"."contact_id"=1)OR"participants"."id"ISNULL)所以我想要(accepted&&contact_id=1)ORNULL这是我在AREL中得到的participants[:accepted].eq(false).and(participants[:contact_id].eq(1).or(participants[:id].is(nil)问题是,这会产生:("participants"."acce

ruby - 在 Ruby 1.8.7 中显示时间减少到毫秒

我试图让我的应用程序显示时间精确到毫秒(例如11:37:53.231),但是1.8.7中的strftime似乎没有选项(http://ruby-doc.org/core-1.8.7/Time.html#method-i-strftime)。在Ruby>=1.9.3中,有%3N选项(http://ruby-doc.org/core-1.9.3/Time.html#method-i-strftime),但它不在1.8.7的文档中,而且似乎也不起作用。这是我在Ruby1.8.7中得到的输出。cur_time=Time.now#=>MonJun2412:43:14+09002013cur_ti